C/C++

推荐列表 站点导航

当前位置:首页 > 脚本编程 > C/C++ >

C++_C++ explicit构造函数实例解析,按照C语言默认规定,只有一个

来源:网络整理  作者:  发布时间:2020-12-22 11:55
C++ explicit构造函数实例解析,按照C语言默认规定,只有一个参数的构造函数也定义了一个隐式转换,将该构造函数对应...

因此,某些时候,explicit 可以有效得防止构造函数的隐式转换带来的错误或者误解

为了避免这种错误的发生,我们可以声明显示的转换,使用explicit 关键字:

当调用   Function(2)   的时候,2   会隐式转换为   A   类型。这种情况常常不是程序员想要的结果,所以,要避免之,就可以这样写:   

class String { String ( const char* p ); // 用C风格的字符串p作为初始化值 //… } String s1 = "hello"; //OK 隐式转换,等价于String s1 = String("hello");

String s2 ( 10 ); //OK 分配10个字节的空字符串 String s3 = String ( 10 ); //OK 分配10个字节的空字符串

class A{ A(int a); }; int Function(A a);

class A { explicit A(int a); }; int Function(A a);

class String { explicit String ( int n ); //本意是预先分配n个字节给字符串 String ( const char* p ); // 用C风格的字符串p作为初始化值 //… }

这样,当调用Function(2)的时候,编译器会给出错误信息(除非Function有个以int为参数的重载形式),这就避免了在程序员毫不知情的情况下出现错误。

String s2 ( 10 ); //OK 分配10个字节的空字符串 String s3 = String ( 10 ); //OK 分配10个字节的空字符串

 

explicit只对构造函数起作用,用来抑制隐式转换。如:   

加上explicit,就抑制了String ( int n )的隐式转换,

s4 和s5 分别把一个int型和char型,隐式转换成了分配若干字节的空字符串,容易令人误解。

String s4 = 10; //编译通过,也是分配10个字节的空字符串 String s5 = 'a'; //编译通过,分配int('a')个字节的空字符串

String s4 = 10; //编译不通过,不允许隐式的转换 String s5 = 'a'; //编译不通过,不允许隐式的转换

按照C语言默认规定,只有一个参数的构造函数也定义了一个隐式转换,将该构造函数对应数据类型的数据转换为该类对象,如下面所示:

总结:explicit只对构造函数起作用,用来抑制隐式转换。

但是有的时候可能会不需要这种隐式转换,如下:

下面两种写法就不允许了:

class String { String ( int n ); //本意是预先分配n个字节给字符串 String ( const char* p ); // 用C风格的字符串p作为初始化值 //… }

下面两种写法比较正常:

下面两种写法仍然正确:

下面两种写法就比较疑惑了:

相关热词: C++ 解析 实例

本站内容来源于网络,如有侵权请与我们联系,我们会及时删除,我们深感抱歉!
注:本站所有信息仅供用于网络技术学习参考,学习中请遵循相关法律法规!

本文地址: https://v30.fanwenzhu.com/jiaob/cjj/7111.shtml

最新文章
只需要在调用Ctrl+B编译后 只需要在调用Ctrl+B编译后

时间:2021-01-13

OpenGL超级宝典visual studio OpenGL超级宝典visual studio

时间:2021-01-04

Directx11 教程(2) 基本的wi Directx11 教程(2) 基本的wi

时间:2021-01-04

LeetCode11ContainerWithMostWate LeetCode11ContainerWithMostWate

时间:2021-01-04

C语言简单IT之家速成 C语言简单IT之家速成

时间:2020-12-27

三分钟了解Activity工作流 三分钟了解Activity工作流

时间:2020-12-27

编译器是如何实现32位整型 编译器是如何实现32位整型

时间:2020-12-27

C++中lower_bound函数和upper C++中lower_bound函数和upper

时间:2020-12-27

Copyright © www.juheyunku.com      关于 | 合作 | 声明 | 联系 | 更新 | 地图 | Tags

C++_C++ explicit构造函数实例解析,按照C语言默认规定,只有一个

2020-12-22 编辑:

因此,某些时候,explicit 可以有效得防止构造函数的隐式转换带来的错误或者误解

为了避免这种错误的发生,我们可以声明显示的转换,使用explicit 关键字:

当调用   Function(2)   的时候,2   会隐式转换为   A   类型。这种情况常常不是程序员想要的结果,所以,要避免之,就可以这样写:   

class String { String ( const char* p ); // 用C风格的字符串p作为初始化值 //… } String s1 = "hello"; //OK 隐式转换,等价于String s1 = String("hello");

String s2 ( 10 ); //OK 分配10个字节的空字符串 String s3 = String ( 10 ); //OK 分配10个字节的空字符串

class A{ A(int a); }; int Function(A a);

class A { explicit A(int a); }; int Function(A a);

class String { explicit String ( int n ); //本意是预先分配n个字节给字符串 String ( const char* p ); // 用C风格的字符串p作为初始化值 //… }

这样,当调用Function(2)的时候,编译器会给出错误信息(除非Function有个以int为参数的重载形式),这就避免了在程序员毫不知情的情况下出现错误。

String s2 ( 10 ); //OK 分配10个字节的空字符串 String s3 = String ( 10 ); //OK 分配10个字节的空字符串

 

explicit只对构造函数起作用,用来抑制隐式转换。如:   

加上explicit,就抑制了String ( int n )的隐式转换,

s4 和s5 分别把一个int型和char型,隐式转换成了分配若干字节的空字符串,容易令人误解。

String s4 = 10; //编译通过,也是分配10个字节的空字符串 String s5 = 'a'; //编译通过,分配int('a')个字节的空字符串

String s4 = 10; //编译不通过,不允许隐式的转换 String s5 = 'a'; //编译不通过,不允许隐式的转换

按照C语言默认规定,只有一个参数的构造函数也定义了一个隐式转换,将该构造函数对应数据类型的数据转换为该类对象,如下面所示:

总结:explicit只对构造函数起作用,用来抑制隐式转换。

但是有的时候可能会不需要这种隐式转换,如下:

下面两种写法就不允许了:

class String { String ( int n ); //本意是预先分配n个字节给字符串 String ( const char* p ); // 用C风格的字符串p作为初始化值 //… }

下面两种写法比较正常:

下面两种写法仍然正确:

下面两种写法就比较疑惑了:

本站内容来源于网络,如有侵权请与我们联系,我们会及时删除,我们深感抱歉!
注:本站所有信息仅供学习参考!
本文地址为 https://v30.fanwenzhu.com/jiaob/cjj/7111.shtml

相关文章

风云图片

推荐阅读

返回C/C++频道首页